package sushu;

import java.util.HashMap;
import java.util.Map;

public class _01质因数 {
    /**
     * 8 = 2 * 2 * 2 2是8的质因数
     * 9 = 3 * 3 3是9的质因数
     *
     * @param args
     */
    public static void main(String[] args) {
        Map<Integer, Integer> map = primeFactor(8);
        System.out.println(map);
    }

    public static Map<Integer, Integer> primeFactor(int num) {
        Map<Integer, Integer> map = new HashMap<Integer, Integer>();  //存放质因数和它出现的次数
        for (int i = 2; i * i <= num; i++){
            while (num % i == 0){
                Integer v = map.get(i);
                if (v == null){
                    map.put(i,1);
                }else {
                    map.put(i,v+1);
                }
                num /= i;
            }
        }
        return map;
    }
}
